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DETAILED ACTION 

1 . Claims 1 -30 are pending. 

Claim Rejections - 35 USC § 102 

(b) the invention was patented or described in a printed publication in this or a foreign country or in public 
use or on sale in this country, more than one year prior to the date of application for patent in the United 
States. 

2. Claims 1-30 are rejected under 35 U.S.C. 102(b) as being anticipated by Tran 
(USPN 5,765,035). 

3. As per Claim 1 , Tran teaches: A pipeline, comprising: 

a plurality of operational stages (Abstract), the stages including: 
a pointer register stage which stores pointer information and updates (Column 9, 
Lines 32-37, the reservation stations. The stations hold instruction information to be 
executed by the functional units. Column 7, Lines 31-57 disclose that registers, which 
generally hold the information in the reservation stations, can make use of indirect 
addressing, such that the value of the register is used as an address (or pointer) to a 
location in memory, where the real data is found. In this embodiment, the basic x86 
registers function as "pointers", which can be stored in the reservation station prior to 
execution); 

a dependency checking stage located downstream of the pointer register stage, 
which determines if instruction dependencies exist and stalls an issue if necessary to 
resolve inter-instruction dependencies (Column 7, Lines 60-64, the reorder buffer does 
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dependency checking, and can stall in the case of memory conflicts (Column 1 1 , Line 
54 - Column 12, Line 17)); 

at least one functional unit providing pointer information updates to the pointer 
register stage (Column 9, Lines 45-50). 

4. As per Claim 2, Tran teaches: The pipeline as recited in claim 1 , further 
comprising a pointer execution stage used before the dependency checking stage such 
that inter-instruction dependency is checked after the pointer execution stage or in 
parallel with pointer execution (Column 9, Lines 45-50. The functional units are part of 
the pointer execution stage). 

5. As per Claim 3, Tran teaches: The pipeline as recited in claim 2, further 
comprising a path for making pointer updates available to the pointer register stage 
before the instruction reaches a write back stage of the pipeline (Column 9, Lines 45-50. 
The result is bypassed back to the reservation stations (pointer register stage), as the 
same time it goes to the reorder buffer). 

6. As per Claim 4, Tran teaches: The pipeline as recited in claim 3, wherein the 
path includes a normal pointer update path which returns pointer information from the at 
least one functional unit (Column 9, Lines 45-50). 
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7. As per Claim 5, Tran teaches: The pipeline as recited in claim 3, further 
comprising a pointer execution bypass making pointer updates available to immediately 
following instructions before a pointer update is written into the pointer register file 
(Column 9, Lines 45-50). 

8. As per Claim 6, Tran teaches: The pipeline as recited in claim 2, further 
comprising a pointer reorder buffer coupled to the pointer register stage to maintain a 
precise state of pointers (Column 7, Lines 60-64, it is part of the dependency checking 
stage). 

9. As per Claim 7, Tran teaches: The pipeline as recited in claim 6, further 
comprising a precise pointer file for storing the precise state of the pointer reorder buffer 
(Figure 1, Register File 218). 

10. As per Claim 8, Tran teaches: The pipeline as recited in claim 7, further 
comprising an interrupt recovery path which keeps the pointer register stage up to date 
with reordering or recovery information from the precise pointer file (Column 10, Lines 
6-16). 

11. As per Claim 9, Tran teaches: The pipeline as recited in claim 1 , further 
comprising a combined pointer reorder buffer/issue stage coupled to the dependence 
checking stage to issue instructions and maintain a precise state/order of pointers 



Application/Control Number: 10/828,794 Page 5 

Art Unit: 2183 

(Column 7, Lines 60-64, and Column 8, Line 46 - Column 9, Line 9. The reorder buffer 
maintains the ordering of the operations, and helps issue in the sense that it forwards 
appropriate data to the reservation station to allow it to issue). 

12. As per Claim 10, Tran teaches: The pipeline as recited in claim 9, wherein the 
combined pointer reorder buffer/issue stage includes a table with a plurality of fields to 
keep identifiers of all pointers that are updated by an instruction, and new values of the 
updated pointers (Column 8, Line 46 - Column 9, Line 6). 

1 3. As per Claim 1 1 , Tran teaches: The pipeline as recited in claim 9, further 
comprising a precise pointer file for storing the precise state of the combined pointer 
reorder buffer/issue stage (Figure 1, Register File 218). 

14. As per Claim 12, Tran teaches: The pipeline as recited in claim 1 1 , further 
comprising an interrupt recovery path, which restores the pointer register stage to the 
precise state from the precise pointer file (Column 10, Lines 6-16). 

15. As per Claim 13, Tran teaches: A pipeline, comprising: 

a plurality of operational stages (Abstract), the stages including: 
a pointer register stage which stores pointer information and updates (Column 9, 
Lines 32-37, the reservation stations. The stations hold instruction information to be 
executed by the functional units. Column 7, Lines 31-57 disclose that registers, which 
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generally hold the information in the reservation stations, can make use of indirect 
addressing, such that the value of the register is used as an address (or pointer) to a 
location in memory, where the real data is found. In this embodiment, the basic x86 
registers function as "pointers", which can be stored in the reservation station prior to 
execution); 

a dependence checking stage located downstream of the pointer register stage, 
which determines if instruction dependencies exist (Column 7, Lines 60-64, the reorder 
buffer does dependency checking, and can stall in the case of memory conflicts 
(Column 11, Line 54 - Column 12, Line 17)); 

a pointer execution stage for processing pointers prior to the dependence 
checking stage (Column 9, Lines 45-50. The functional units are part of the pointer 
execution stage), the pointer execution stage providing pointer updates to the pointer 
register stage via an early pointer update path (Column 9, Lines 45-50. The result is 
bypassed back to the reservation stations (pointer register stage), as the same time it 
goes to the reorder buffer); and 

at least one functional unit providing pointer information updates to the pointer 
register stage such that pointer information is processed and updated to the pointer 
register stage (Column 9, Lines 45-50). 

16. As per Claim 14, Tran teaches: The pipeline as recited in claim 13, further 
comprising a pointer reorder buffer coupled to the pointer register stage to maintain a 
precise state of pointers (Column 7, Lines 60-64, it is part of the dependency checking 
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17. As per Claim 15, Tran teaches: The pipeline as recited in claim 14, further 
comprising a precise pointer file for storing the precise state of the pointer reorder buffer 
(Figure 1, Register File 218). 

18. As per Claim 16, Tran teaches: The pipeline as recited in claim 15, further 
comprising an interrupt recovery path which keeps the pointer register stage up to date 
with reordering or recovery information from the precise pointer file (Column 10, Lines 
6-16). 

19. As per Claim 17, Tran teaches: The pipeline as recited in claim 13, further 
comprising a normal pointer update path which returns pointer information from the at 
least one functional unit (Column 9, Lines 45-50). 

20. As per Claim 18, Tran teaches: The pipeline as recited in claim 13, further 
comprising a combined pointer reorder buffer/issue stage coupled to the dependence 
checking stage to issue instructions and maintain a precise state/order of pointers 
(Column 7, Lines 60-64, and Column 8, Line 46 - Column 9, Line 9. The reorder buffer 
maintains the ordering of the operations, and helps issue in the sense that it forwards 
appropriate data to the reservation station to allow it to issue). 
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21 . As per Claim 19, Tran teaches: The pipeline as recited in claim 18, wherein the 
combined pointer reorder buffer/issue stage includes a table with a plurality of fields to 
keep identifiers of all pointers that are updated by an instruction, and new values of the 
updated pointers (Column 8, Line 46 - Column 9, Line 6). 

22. As per Claim 20, Tran teaches: The pipeline as recited in claim 18, further 
comprising a precise pointer file for storing the precise state of the combined pointer 
reorder buffer/issue stage (Figure 1, Register File 218). 

23. As per Claim 21 , Tran teaches: The pipeline as recited in claim 20, further 
comprising an interrupt recovery path, which restores the pointer register stage to the 
precise state from the precise pointer file (Column 10, Lines 6-16). 

24. As per Claim 22, Tran teaches: A method for updating pointers ahead of an 
instruction, comprising the steps of: 

providing a plurality of operational stages (Abstract), including a pointer register 
stage which stores pointer information and updates (Column 9, Lines 32-37, the 
reservation stations. The stations hold instruction information to be executed by the 
functional units. Column 7, Lines 31-57 disclose that registers, which generally hold the 
information in the reservation stations, can make use of indirect addressing, such that 
the value of the register is used as an address (or pointer) to a location in memory, 
where the real data is found. In this embodiment, the basic x86 registers function as 
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"pointers", which can be stored in the reservation station prior to execution), a 
dependence checking stage located downstream of the pointer register stage, which 
determines if instruction dependencies exist (Column 7, Lines 60-64, the reorder buffer 
does dependency checking, and can stall in the case of memory conflicts (Column 1 1 , 
Line 54 - Column 12, Line 17)), and at least one functional unit providing pointer 
information updates to the pointer register stage (Column 9, Lines 45-50); and 

processing pointer information to update the pointer information for the pointer 
register stage so that updated pointer information is available (Column 8, Lines 60-65). 

25. As per Claim 23, Tran teaches: The method as recited in claim 22, further 
comprising a step of providing pointer updates to the pointer register stage via an early 
pointer update path by providing a pointer execution stage used before the pointer 
register stage and the dependence checking stage (Column 9, Lines 45-50. The result 
is bypassed back to the reservation stations (pointer register stage), as the same time it 
goes to the reorder buffer). 

26. As per Claim 24, Tran teaches: The method as recited in claim 23, further 
comprising a step of maintaining a precise state of pointers by employing a pointer 
reorder buffer (Column 7, Lines 60-64, it is part of the dependency checking stage). 

27. As per Claim 25, Tran teaches: The method as recited in claim 24, further 
comprising a step of storing the precise state of the pointer reorder buffer in a precise 
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pointer file (Figure 1, Register File 218 holds the precise state). 

28. As per Claim 26, Tran teaches: The method as recited in claim 24, further 
comprising updating reordering or recovery information from the precise pointer file 
using an interrupt recovery path to the pointer register stage (Column 10, Lines 6-16). 

29. As per Claim 27, Tran teaches: The method as recited in claim 23, further 
comprising maintaining a precise state/order of pointers using a combined pointer 
reorder buffer/issue stage coupled to the rename and dependence checking stage 
(Column 7, Lines 60-64, and Column 8, Line 46 - Column 9, Line 9. The reorder buffer 
maintains the ordering of the operations, and helps issue in the sense that it forwards 
appropriate data to the reservation station to allow it to issue). 

30. As per Claim 28, Tran teaches: The method as recited in claim 27, wherein the 
combined pointer reorder buffer/issue stage includes a table with a plurality of fields to 
keep identifiers of all pointers that are updated by an instruction, and new values of the 
updated pointers (Column 8, Line 46 - Column 9, Line 6). 

31 . As per Claim 29, Tran teaches: The method as recited in claim 27, further 
comprising storing the precise state of the combined pointer reorder buffer/issue stage 
using a precise pointer file (Figure 1, Register File 218). 
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32. As per Claim 30, Tran teaches: The method as recited in claim 29, further 
comprising an interrupt recovery path which keeps the pointer register stage up to date 
with reordering or recovery information from the precise pointer file (Column 10, Lines 
6-16). 

Conclusion 

33. The prior art made of record and not relied upon is considered pertinent to 
applicant's disclosure as follows. Applicant is reminded that in amending in response to 
a rejection of claims, the patentable novelty must be clearly shown in view of the state 
of the art disclosed by the references cited and the objections made. Applicant must 
also show how the amendments avoid such references and objections. See 37 CFR § 
1.111(c). 

34. Zuraski et al. (USPN 5,590,352) teaches a system implementing register 
renaming, and using pointers to address registers. 

35. Hilgendorf et al. (USPN 5,930,491) teaches a system with a combined reorder 
buffer and reservation station. 

Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Robert E. Fennema whose telephone number is (571) 
272-2748. The examiner can normally be reached on Monday-Friday, 8:00-5:30. 
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If attempts to reach the examiner by telephone are unsuccessful, the examiner's 
supervisor, Eddie Chan can be reached on (571) 272-4162. The fax phone number for 
the organization where this application or proceeding is assigned is 571-273-8300. 

Information regarding the status of an application may be obtained from the 
Patent Application Information Retrieval (PAIR) system. Status information for 
published applications may be obtained from either Private PAIR or Public PAIR. 
Status information for unpublished applications is available through Private PAIR only. 
For more information about the PAIR system, see http://pair-direct.uspto.gov. Should 
you have questions on access to the Private PAIR system, contact the Electronic 
Business Center (EBC) at 866-217-9197 (toll-free). 



Robert E Fennema 

Examiner 
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